<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="${package.Mapper}.${table.mapperName}">

<#if enableCache>
    <!-- 开启二级缓存 -->
    <cache type="org.mybatis.caches.ehcache.LoggingEhcache"/>

</#if>
    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="${package.Entity}.${entity}">
<#list table.fields as field>
<#if field.keyFlag><#--生成主键排在第一位-->
        <id column="${field.name}" property="${field.propertyName}" />
</#if>
</#list>

<#list table.commonFields as field><#--生成公共字段 -->
        <result column="${field.name}" property="${field.propertyName}" />
</#list>
<#list table.fields as field>
<#if !field.keyFlag><#--生成普通字段 -->
        <result column="${field.name}" property="${field.propertyName}" />
</#if>
</#list>
    </resultMap>
    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
        <#list table.commonFields as field>
            ${field.columnName},
        </#list>
        ${table.fieldNames}
    </sql>

    <sql id = "search_conditions">
        <#list table.fields as field>
            <if test="${field.propertyName} != null and ${field.propertyName} != '' ">
                and  ${field.name} = ${"#"+"{"+"${field.propertyName}"+ "}" }
            </if>
        </#list>
    </sql>


    <!-- 分页查询 -->
    <select id="queryPage"  parameterType="${package.Entity}.query.${entity}Query" resultMap="BaseResultMap">
        select
       <include refid="Base_Column_List"></include>
        from ${table.name}
        <where>
            <#list table.fields as field>
                <if test="query.${field.propertyName} != null and query.${field.propertyName} != '' ">
                    and  ${field.name} = ${"#"+"{"+"query.${field.propertyName}"+ "}" }
                </if>
            </#list>
        </where>

    </select>



</mapper>